<template>
  <div>
    <div>
      <div style="display: flex; justify-content: space-between">
        <div>
          <el-input
            style="width: 300px; margin-right: 10px"
            prefix-icon="el-icon-search"
            v-model="empName"
            @keydown.enter.native="initEmps"
            clearable
            :disabled="showAdvanceSearchVisible"
            @clear="initEmps"
            placeholder="请输入员工名进行搜索..."
          ></el-input>
          <el-button
            type="primary"
            icon="el-icon-search"
            @click="initEmps"
            :disabled="showAdvanceSearchVisible"
            >搜索</el-button
          >
          <el-button
            type="primary"
            @click="showAdvanceSearchVisible = !showAdvanceSearchVisible"
          >
            <!-- 设置变量 -->
            <i
              :class="
                showAdvanceSearchVisible
                  ? 'fa fa-angle-double-up'
                  : 'fa fa-angle-double-down'
              "
              aria-hidden="true"
            ></i>
            高级搜索</el-button
          >
        </div>
        <div>
          <!-- 文件上传成功的钩子 文件上传失败的钩子 -->
          <!-- action改成后端接口地址 -->
          <!-- 因为整个项目被jwt令牌进行了拦截 所以在请求的时候带上authorcatio..    =>headers-->
          <el-upload
            style="display: inline-flex; margin-right: 8px"
            :headers="headers"
            :show-file-list="false"
            :before-upload="beforeUpload"
            :on-success="onSuccess"
            :on-error="onError"
            :disabled="importDataDisabled"
            action="/employee/basic/import"
          >
            <el-button
              type="success"
              icon="importDataBtnIcon"
              :disabled="importDataDisabled"
            >
              {{ importDataBtnText }}</el-button
            >
          </el-upload>

          <el-button @click="exportData" type="success" icon="el-icon-download">
            导出数据</el-button
          >
          <el-button type="primary" icon="el-icon-plus" @click="showAddEmpView"
            >添加员工</el-button
          >
        </div>
      </div>
    </div>
    <!-- 222222 -->
    <transition name="slide-fade">
      <div
        v-show="showAdvanceSearchVisible"
        style="
          border: 1px solid #409eff;
          border-radius: 5px;
          box-sizing: border-box;
          padding: 5px;
          margin: 10px 0px;
        "
      >
        <el-row>
          <el-col :span="5">
            政治面貌：
            <el-select
              v-model="searchValue.politicId"
              size="mini"
              style="width: 130px"
              placeholder="政治面貌"
            >
              <!-- v-for="item in options" 数据中的数组 item代表里面的每一项  options代表数据对象 -->
              <el-option
                v-for="item in politicsstatus"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              >
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            民族:
            <el-select
              v-model="searchValue.nationId"
              size="mini"
              style="width: 130px"
              placeholder="民族"
            >
              <el-option
                v-for="item in nations"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              >
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            职位:
            <el-select
              v-model="searchValue.posId"
              size="mini"
              style="width: 130px"
              placeholder="职位"
            >
              <el-option
                v-for="item in positions"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              >
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="4">
            职称:
            <el-select
              v-model="searchValue.jobLevelId"
              size="mini"
              style="width: 130px"
              placeholder="职称"
            >
              <el-option
                v-for="item in joblevels"
                :key="item.id"
                :label="item.name"
                :value="item.id"
              >
              </el-option>
            </el-select>
          </el-col>
          <el-col :span="7">
            聘用形式:
            <el-radio-group v-model="searchValue.engageForm">
              <el-radio label="劳动合同">劳动合同</el-radio>
              <el-radio label="劳务合同">劳务合同</el-radio>
            </el-radio-group>
          </el-col>
        </el-row>
        <!-- 第二行 -->
        <el-row style="margin-top: 10px">
          <el-col :span="5">
            所属部门：
            <el-popover
              placement="bottom"
              title="请选择部门"
              width="200"
              trigger="manual"
              v-model="visible2"
            >
              <!-- 树形控件 -->
              <el-tree
                :data="allDeps"
                :props="defaultProps"
                default-expand-all
                @node-click="searchHandleNodeClick"
              ></el-tree>
              <!-- 展示下树形控件 ;div->但是看起来还是输入框的形状-->
              <!-- border-radius圆角 -->
              <!-- cursor: pointer 鼠标换成手指手势 -->
              <!-- reference 触发点选事件 -->
              <div
                slot="reference"
                style="
              width: 130px;
              display: inline-flex;
              border: 1px solid #dedede;
              height: 24px
              border-radius: 5px;
              cursor: pointer;
              align-items: center;
              font-size: 13px;
              padding-left: 8px;
              box-sizing: border-box;
            "
                @click="showDepView2"
              >
                {{ inputDepName }}
              </div>
            </el-popover>
          </el-col>
          <el-col :span="10">
            入职日期:
            <el-date-picker
              size="mini"
              v-model="searchValue.beginDateScope"
              type="daterange"
              value-format="yyyy-MM-dd"
              unlink-panels
              range-separator="至"
              start-placeholde="开始日期"
              end-placeholde="结束日期"
            >
            </el-date-picker>
          </el-col>
          <!-- offset偏移量 -->
          <el-col :span="5" :offset="4">
            <el-button size="mini" @click="cancel">取消</el-button>
            <!-- advanced-》表示里面有一个类型并且这个类型是advanced -->
            <el-button
              @click="initEmps('advanced')"
              size="mini"
              icon="el-icon-search"
              type="primary"
              >搜索</el-button
            >
          </el-col>
        </el-row>
      </div>
    </transition>
    <div style="'margin-top: 10px">
      <el-table
        :data="emps"
        stripe
        border
        style="width: 100%"
        v-loading="loading"
        element-loading-text="拼命加载中"
        element-loading-spinner="el-icon-loading"
        element-loading-background="rgba(0, 0, 0, 0.8)"
      >
        <el-table-column type="selection" width="55"></el-table-column>
        <!-- fixed默认就是靠左边冻结 -->
        <!-- prop和 ：data="emps"里面的emps绑定 -->
        <el-table-column
          prop="name"
          label="姓名"
          fixed
          align="left"
          width="90"
        ></el-table-column>
        <el-table-column
          prop="workID"
          label="工号"
          align="left"
          width="85"
        ></el-table-column>
        <el-table-column
          prop="gender"
          label="性别"
          width="50"
        ></el-table-column>
        <el-table-column
          prop="birthday"
          label="出生日期"
          width="95"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="idCard"
          label="身份证号码"
          align="left"
          width="150"
        ></el-table-column>
        <el-table-column
          prop="wedlock"
          label="婚姻状况"
          width="70"
        ></el-table-column>
        <!-- 带id,后面是数字的 是别的表的数据 -->
        <el-table-column
          prop="nation.name"
          label="民族"
          width="50"
        ></el-table-column>
        <el-table-column
          prop="nativePlace"
          label="籍贯"
          width="80"
        ></el-table-column>
        <el-table-column
          prop="politicsStatus.name"
          label="政治面貌"
          width="100"
        ></el-table-column>
        <el-table-column
          prop="email"
          label="邮箱"
          align="left"
          width="180"
        ></el-table-column>
        <el-table-column
          prop="phone"
          label="电话号码"
          width="100"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="address"
          label="联系地址"
          width="270"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="department.name"
          label="所属部门"
          width="100"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="joblevel.name"
          label="职称"
          width="100"
        ></el-table-column>
        <el-table-column
          prop="position.name"
          label="职位"
          width="100"
        ></el-table-column>
        <el-table-column
          prop="engageForm"
          label="聘用形式"
          width="100"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="tiptopDegree"
          label="最高学历"
          width="80"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="school"
          label="毕业院校"
          width="150"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="specialty"
          label="专业"
          width="150"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="workState"
          label="在职状态"
          width="70"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="beginDate"
          label="入职日期"
          width="95"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="conversionTime"
          label="转正日期"
          width="95"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="beginContract"
          label="合同起始日期"
          width="95"
          align="left"
        ></el-table-column>
        <el-table-column
          prop="endContract"
          label="合同截止日期"
          width="95"
          align="left"
        ></el-table-column>
        <el-table-column label="合同期限" width="100" align="left">
          <template slot-scope="scope">
            <!-- row整行的json数据 -->
            <el-tag>{{ scope.row.contractTerm }}</el-tag
            >年
          </template>
        </el-table-column>
        <el-table-column label="操作" fixed="right" width="200"
          >、
          <!-- 有scope可以拿去取一整条json数据 -->
          <template slot-scope="scope">
            <!-- 要在编辑员工信息的弹出框去显示这一条完整的信息 -->
            <el-button
              @click="showEditEmpView(scope.row)"
              style="padding: 3px"
              size="mini"
              >编辑</el-button
            >
            <el-button style="padding: 3px" size="mini" type="primary"
              >查看高级资料</el-button
            >
            <el-button
              style="padding: 3px"
              size="mini"
              type="danger"
              @click="deleteEmp(scope.row)"
              >删除</el-button
            >
          </template>
        </el-table-column>
      </el-table>
      <div style="display: flex; justify-content: flex-end">
        <!-- 分页 -->
        <!-- pager每一页的条数  sizes当前显示多少条-->
        <!-- current-change currentChange改变时触发 当前页 -->
        <el-pagination
          background
          @current-change="currentChange"
          @size-change="sizeChange"
          layout="sizes, prev, pager, next, jumper, ->, total, slot"
          :total="total"
        ></el-pagination>
      </div>
    </div>
    <!-- 弹框复用 -->
    <el-dialog :title="title" :visible.sync="dialogVisible" width="80%">
      <div>
        <!-- el-forn表单提交 -->
        <el-form ref="empForm" :model="emp" :rules="rules">
          <!-- 第一行 -->
          <el-row>
            <!-- col纵 -->
            <!-- el-col 24分栏  :span="6"代表宽度 宽度相加=24 -->
            <el-col :span="6">
              <el-form-item label="姓名：" prop="name">
                <el-input
                  size="mini"
                  prefix-icon="el-icon-edit"
                  style="width: 150px"
                  v-model="emp.name"
                  placeholder="请输入员工姓名"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="性别：" prop="gender">
                <el-radio-group v-model="emp.gender" style="margin-top: 8px">
                  <el-radio label="男">男</el-radio>
                  <el-radio label="女">女</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="出生日期：" prop="birthday">
                <el-date-picker
                  v-model="emp.birthday"
                  type="date"
                  size="mini"
                  style="width: 150px"
                  value-format="yyyy-MM-dd"
                  placeholder="出生日期"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="政治面貌：" prop="politicId">
                <el-select
                  v-model="emp.politicId"
                  size="mini"
                  style="width: 200px"
                  placeholder="政治面貌"
                >
                  <!-- v-for="item in options" 数据中的数组 item代表里面的每一项  options代表数据对象 -->
                  <el-option
                    v-for="item in politicsstatus"
                    :key="item.id"
                    :label="item.name"
                    :value="item.id"
                  >
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- 第二行 row行 -->
          <el-row>
            <el-col :span="6">
              <el-form-item label="民族：" prop="nationId">
                <el-select
                  v-model="emp.nationId"
                  size="mini"
                  style="width: 150px"
                  placeholder="民族"
                >
                  <el-option
                    v-for="item in nations"
                    :key="item.id"
                    :label="item.name"
                    :value="item.id"
                  >
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="籍贯：" prop="nativePlace">
                <el-input
                  v-model="emp.nativePlace"
                  placeholder="请输入籍贯"
                  prefix-icon="el-icon-edit"
                  size="mini"
                  style="width: 150px"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="电子邮箱：" prop="email">
                <el-input
                  v-model="emp.email"
                  placeholder="请输入电子邮箱"
                  size="mini"
                  style="width: 150px"
                  prefix-icon="el-icon-message"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="联系地址：" prop="address">
                <el-input
                  v-model="emp.address"
                  placeholder="请输入联系地址"
                  size="mini"
                  style="width: 200px"
                  prefix-icon="el-icon-edit"
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- 第三行 -->
          <el-row>
            <el-col :span="6">
              <el-form-item label="职位：" prop="posId">
                <el-select
                  v-model="emp.posId"
                  size="mini"
                  style="width: 150px"
                  placeholder="职位"
                >
                  <el-option
                    v-for="item in positions"
                    :key="item.id"
                    :label="item.name"
                    :value="item.id"
                  >
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="职称：" prop="jobLevelId">
                <el-select
                  v-model="emp.jobLevelId"
                  size="mini"
                  style="width: 150px"
                  placeholder="职称"
                >
                  <el-option
                    v-for="item in joblevels"
                    :key="item.id"
                    :label="item.name"
                    :value="item.id"
                  >
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="所属部门：" prop="departmentId">
                <!-- Popover弹出框 小弹出框 -->
                <!-- visble 当你点击的时候，如果是true就显示,反之亦然 -->
                <el-popover
                  placement="bottom"
                  title="请选择部门"
                  width="200"
                  trigger="manual"
                  v-model="visible"
                >
                  <!-- 树形控件 -->
                  <el-tree
                    :data="allDeps"
                    :props="defaultProps"
                    default-expand-all
                    @node-click="handleNodeClick"
                  ></el-tree>
                  <!-- 展示下树形控件 ;div->但是看起来还是输入框的形状-->
                  <!-- border-radius圆角 -->
                  <!-- cursor: pointer 鼠标换成手指手势 -->
                  <!-- reference 触发点选事件 -->
                  <div
                    slot="reference"
                    style="
                      width: 150px;
                      display: inline-flex;
                      border: 1px solid #dedede;
                      height: 24px;
                      border-radius: 5px;
                      cursor: pointer;
                      align-items: center;
                      font-size: 13px;
                      padding-left: 8px;
                      box-sizing: border-box;
                    "
                    @click="showDepView"
                  >
                    {{ inputDepName }}
                  </div>
                </el-popover>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="电话号码：" prop="phone">
                <el-input
                  v-model="emp.phone"
                  placeholder="请输入电话号码"
                  prefix-icon="el-icon-phone"
                  size="mini"
                  style="width: 200px"
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- 第四行 -->
          <el-row>
            <el-col :span="6">
              <el-form-item label="工号：" prop="workID">
                <!-- disabled 禁用 因为不需要前端输入 后端传过来直接显示 -->
                <el-input
                  v-model="emp.workID"
                  placeholder="请输入工号"
                  prefix-icon="el-icon-edit"
                  disabled
                  size="mini"
                  style="width: 150px"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="学历：" prop="tiptopDegree">
                <el-select
                  v-model="emp.tiptopDegree"
                  size="mini"
                  style="width: 150px"
                  placeholder="学历"
                >
                  <!-- 没有id 是前端写死的数据 所以都写item-->
                  <el-option
                    v-for="item in tiptopDegrees"
                    :key="item"
                    :label="item"
                    :value="item"
                  >
                  </el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="毕业院校：" prop="school">
                <el-input
                  v-model="emp.school"
                  placeholder="请输入学校"
                  size="mini"
                  style="width: 150px"
                  prefix-icon="el-icon-edit"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="专业名称：" prop="specialty">
                <el-input
                  v-model="emp.specialty"
                  placeholder="请输入专业名称"
                  size="mini"
                  style="width: 200px"
                  prefix-icon="el-icon-edit"
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- 第五行 -->
          <el-row>
            <el-col :span="6">
              <el-form-item label="入职日期：" prop="beginDate">
                <el-date-picker
                  v-model="emp.beginDate"
                  type="date"
                  size="mini"
                  style="width: 120px"
                  value-format="yyyy-MM-dd"
                  placeholder="入职日期"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="5">
              <el-form-item label="转正日期：" prop="conversionTime">
                <el-date-picker
                  v-model="emp.conversionTime"
                  type="date"
                  size="mini"
                  style="width: 120px"
                  value-format="yyyy-MM-dd"
                  placeholder="转正日期"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="6">
              <el-form-item label="合同起始日期：" prop="beginContract">
                <el-date-picker
                  v-model="emp.beginContract"
                  type="date"
                  size="mini"
                  style="width: 135px"
                  value-format="yyyy-MM-dd"
                  placeholder="合同起始日期"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
            <el-col :span="7">
              <el-form-item label="合同截至日期：" prop="endContract">
                <el-date-picker
                  v-model="emp.endContract"
                  type="date"
                  size="mini"
                  style="width: 170px"
                  value-format="yyyy-MM-dd"
                  placeholder="合同截至日期"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- 第六行 -->
          <el-row>
            <el-col :span="8">
              <el-form-item label="身份证号码：" prop="idCard">
                <el-input
                  v-model="emp.idCard"
                  placeholder="请输入身份证号码"
                  prefix-icon="el-icon-edit"
                  size="mini"
                  style="width: 180px"
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="聘用形式：" prop="engageForm">
                <el-radio-group
                  v-model="emp.engageForm"
                  style="margin-top: 8px"
                >
                  <el-radio label="劳动合同">劳动合同</el-radio>
                  <el-radio label="劳务合同">劳务合同</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="婚姻状况：" prop="wedlock">
                <el-radio-group v-model="emp.wedlock" style="margin-top: 8px">
                  <el-radio label="已婚">已婚</el-radio>
                  <el-radio label="未婚">未婚</el-radio>
                  <el-radio label="离异">离异</el-radio>
                </el-radio-group>
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="dialogVisible = false">取 消</el-button>
        <el-button type="primary" @click="doAddEmp">确 定</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>
export default {
  name: "EmpBasic",
  data() {
    return {
      searchValue: {
        politicId: null,
        nationId: null,
        posId: null,
        jobLevelId: null,
        engageForm: "",
        departmentId: "",
        beginDateScope: null,
      },
      showAdvanceSearchVisible: false,
      headers: {
        Authorization: window.sessionStorage.getItem("tokenStr"),
      },
      importDataDisabled: false,
      importDataBtnText: "导入数据",
      importDataBtnIcon: "el-icon-upload2",
      title: "",
      rules: {
        name: [{ required: true, message: "请输入员工姓名", trigger: "blur" }],
        gender: [
          { required: true, message: "请输入员工性别", trigger: "blur" },
        ],
        birthday: [
          { required: true, message: "请输入出生日期", trigger: "blur" },
        ],
        idCard: [
          { required: true, message: "请输入身份证号码", trigger: "blur" },
          {
            pattern: /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/,
            message: "身份证号码不正确",
            trigger: "blur",
          },
        ],
        wedlock: [
          { required: true, message: "请输入婚姻状况", trigger: "blur" },
        ],
        nationId: [{ required: true, message: "请输入民族", trigger: "blur" }],
        nativePlace: [
          { required: true, message: "请输入籍贯", trigger: "blur" },
        ],
        politicId: [
          { required: true, message: "请输入政治面貌", trigger: "blur" },
        ],
        email: [
          { required: true, message: "请输入邮箱地址", trigger: "blur" },
          { type: "email", message: "邮箱地址格式不正确", trigger: "blur" },
        ],
        phone: [{ required: true, message: "请输入电话号码", trigger: "blur" }],
        address: [
          { required: true, message: "请输入员工地址", trigger: "blur" },
        ],
        departmentId: [
          { required: true, message: "请选择部门", trigger: "blur" },
        ],
        jobLevelId: [
          { required: true, message: "请输入职称", trigger: "blur" },
        ],
        posId: [{ required: true, message: "请选择职位", trigger: "blur" }],
        engageForm: [
          { required: true, message: "请选择聘用形式", trigger: "blur" },
        ],
        tiptopDegree: [
          { required: true, message: "请选择学历", trigger: "blur" },
        ],
        specialty: [{ required: true, message: "请输入专业", trigger: "blur" }],
        school: [
          { required: true, message: "请输入毕业院校", trigger: "blur" },
        ],
        beginDate: [
          { required: true, message: "请输入入职日期", trigger: "blur" },
        ],
        workState: [
          { required: true, message: "请输入工作状态", trigger: "blur" },
        ],
        wordkID: [{ required: true, message: "请输入工号", trigger: "blur" }],
        contractTerm: [
          { required: true, message: "请输入合同期限", trigger: "blur" },
        ],
        conversionTime: [
          { required: true, message: "请输入转正日期", trigger: "blur" },
        ],
        notWorkDate: [
          { required: true, message: "请输入离职日期", trigger: "blur" },
        ],
        beginContract: [
          { required: true, message: "请输入合同起始日期", trigger: "blur" },
        ],
        endContract: [
          { required: true, message: "请输入合同结束日期", trigger: "blur" },
        ],
        workAge: [{ required: true, message: "请输入工龄", trigger: "blur" }],
      },
      // 回显部门
      inputDepName: "",
      allDeps: [],
      defaultProps: {
        children: "children",
        label: "name",
      },
      emps: [],
      loading: false,
      // 总共的条数
      total: 0,
      //   当前页
      currentPage: 1,
      size: 10,
      // 员工名
      empName: "",
      dialogVisible: false,
      // 表单验证对象
      emp: {
        id: null,
        name: "",
        gender: "",
        birthday: "",
        idCard: "",
        wedlock: "",
        nationId: null,
        nativePlace: "",
        politicId: null,
        email: "",
        phone: "",
        address: "",
        departmentId: null,
        joblevelId: null,
        posId: null,
        engageForm: "",
        tiptopDegree: "",
        specialty: "",
        school: "",
        beginDate: "",
        workState: "在职",
        workID: "",
        contractTerm: null,
        conversionTime: "",
        notWorkDate: null,
        beginContract: "",
        endContract: "",
        workAge: "",
        salaryId: null,
      },
      // 后端传来，前端用来接受 民族
      nations: [],
      // 职称不怎么变动，把职称放入sessionStorage里面  放了之后就不需要去查了
      // 职称
      joblevels: [],
      // 政治面貌
      politicsstatus: [],
      // 职位
      positions: [],
      // 学历  前端写死
      tiptopDegrees: [
        "博士",
        "硕士",
        "本科",
        "大专",
        "高中",
        "初中",
        "小学",
        "其他",
      ],
      visible: false,
      visible2: false,
    };
  },
  mounted() {
    this.initEmps();
    this.initData();
    this.initPositions();
  },
  methods: {
    cancel(){
      this.searchValue={
        politicId: null,
        nationId: null,
        posId: null,
        jobLevelId: null,
        engageForm: '',
        departmentId: null,
        beginDateScope: null,
      }
      this.inputDepName = ''
      this.initEmps('advanced')
    },
    searchHandleNodeClick(data) {
      this.inputDepName = data.name;
      this.searchValue.departmentId = data.id;
      this.visible2 = !this.visible2;
    },
    onSuccess() {
      this.importDataBtnIcon = "el-icon-upload2";
      this.importDataBtnText = "导入数据";
      this.importDataDisabled = false;
      this.initEmps();
    },
    onError() {
      this.importDataBtnIcon = "el-icon-upload2";
      this.importDataBtnText = "导入数据";
      this.importDataDisabled = false;
    },
    beforeUpload() {
      this.importDataBtnIcon = "el-icon-loading";
      this.importDataBtnText = "正在导入";
      this.importDataDisabled = true;
    },
    exportData() {
      this.downloadRequest("/employee/basic/export");
    },
    showEditEmpView(data) {
      this.title = "编辑员工信息";
      // 展示数据
      this.emp = data;
      // 部门不在emp里，单独定义的
      this.inputDepName = data.department.name;
      this.initPositions();
      this.dialogVisible = true;
    },
    deleteEmp(data) {
      this.$confirm("此操作将永久删除" + data.name + ", 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          this.deleteRequest("/employee/basic/" + data.id).then((resp) => {
            if (resp) {
              this.initEmps();
            }
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
    // 确定事件到底是添加员工还是更新员工
    // 如果编辑的时候，是把整条数据传进去的，肯定会有id.只需要判断有没有对应的id! 有id=更新，无id就是对应的添加
    doAddEmp() {
      // 编辑存在id
      if (this.emp.id) {
        this.$refs["empForm"].validate((valid) => {
          if (valid) {
            this.putRequest("/employee/basic/", this.emp).then((resp) => {
              if (resp) {
                this.dialogVisible = false;
                this.initEmps();
              }
            });
          }
        });
      } else {
        this.$refs["empForm"].validate((valid) => {
          if (valid) {
            this.postRequest("/employee/basic/", this.emp).then((resp) => {
              if (resp) {
                this.dialogVisible = false;
                this.initEmps();
              }
            });
          }
        });
      }
    },
    handleNodeClick(data) {
      this.inputDepName = data.name;
      // id传到emp对象里面
      this.emp.departmentId = data.id;
      this.visible = !this.visible;
    },
    showDepView() {
      this.visible = !this.visible; // 取反
    },
    showDepView2() {
      this.visible2 = !this.visible2;
    },
    // 获取最大工号
    getMaxWorkID() {
      this.getRequest("/employee/basic/maxWorkID").then((resp) => {
        if (resp) {
          this.emp.workID = resp.obj; // 后端响应里面的obj里的数字
        }
      });
    },
    // 职位    有可能变动 所以不放在sessionStorage里
    initPositions() {
      this.getRequest("/employee/basic/positions").then((resp) => {
        if (resp) {
          this.positions = resp;
        }
      });
    },
    // 初始化数据
    // 放不怎么变动的数据
    initData() {
      // 民族
      if (!window.sessionStorage.getItem("nations")) {
        // 如果sessionStorage里面没有 就去后端找
        this.getRequest("/employee/basic/nations").then((resp) => {
          if (resp) {
            this.nations = resp;
            // 然后在sessionStorage里面存入  拿到的是对象，转成字符串
            window.sessionStorage.setItem("nations", JSON.stringify(resp));
          }
        });
      } else {
        // 如果要的数据存在sessionStorage里
        // 拿到的是字符串 所以需要转一下JSON.parse 转成js对象
        this.nations = JSON.parse(window.sessionStorage.getItem("nations"));
      }
      // 职称
      if (!window.sessionStorage.getItem("joblevels")) {
        this.getRequest("/employee/basic/joblevels").then((resp) => {
          if (resp) {
            this.joblevels = resp;
            window.sessionStorage.setItem("joblevels", JSON.stringify(resp));
          }
        });
      } else {
        this.joblevels = JSON.parse(window.sessionStorage.getItem("joblevels"));
      }

      // 政治面貌
      if (!window.sessionStorage.getItem("politicsstatus")) {
        this.getRequest("/employee/basic/politicsstatus").then((resp) => {
          if (resp) {
            this.politicsstatus = resp;
            window.sessionStorage.setItem(
              "politicsstatus",
              JSON.stringify(resp)
            );
          }
        });
      } else {
        this.politicsstatus = JSON.parse(
          window.sessionStorage.getItem("politicsstatus")
        );
      }
      // 所有部门
      if (!window.sessionStorage.getItem("allDeps")) {
        this.getRequest("/employee/basic/deps").then((resp) => {
          if (resp) {
            this.allDeps = resp;
            window.sessionStorage.setItem("allDeps", JSON.stringify(resp));
          }
        });
      } else {
        this.allDeps = JSON.parse(window.sessionStorage.getItem("allDeps"));
      }
    },
    // 添加员工
    showAddEmpView() {
      this.title = "添加员工";
      // 添加员工之前清空数据
      this.emp = {
        id: null,
        name: "",
        gender: "",
        birthday: "",
        idCard: "",
        wedlock: "",
        nationId: null,
        nativePlace: "",
        politicId: null,
        email: "",
        phone: "",
        address: "",
        departmentId: null,
        joblevelId: null,
        posId: null,
        engageForm: "",
        tiptopDegree: "",
        specialty: "",
        school: "",
        beginDate: "",
        workState: "在职",
        workID: "",
        contractTerm: null,
        conversionTime: "",
        notWorkDate: null,
        beginContract: "",
        endContract: "",
        workAge: "",
        salaryId: null,
      };
      this.inputDepName = "";
      // 打开对话框时调用
      this.getMaxWorkID();
      this.initPositions();
      this.dialogVisible = true;
    },
    // size条/页
    sizeChange(size) {
      this.size = size;
      this.initEmps('advanced');
    },
    // currentPage当前页数
    currentChange(currentPage) {
      this.currentPage = currentPage;
      // 一定要加advanced 不然高级搜索分页控件会出问题
      this.initEmps('advanced');
    },
    // 初始化员工
    initEmps(type) {
      this.loading = true;
      // 现在要用其他属性去传参，->定义url
      let url =
        '/employee/basic/?currentPage='
         +this.currentPage 
         +'&size=' +
        this.size ;
        // 如果知道是高级搜索
        if(type && type == 'advanced') { // 是高级搜索
        if (this.searchValue.politicId) {
          url += "&politicId=" + this.searchValue.politicId;
        }
        if (this.searchValue.nationId) {
          url += "&nationId=" + this.searchValue.nationId;
        }
        if (this.searchValue.posId) {
          url += "&posId=" + this.searchValue.posId;
        }
        if (this.searchValue.jobLevelId) {
          url += "&jobLevelId=" + this.searchValue.jobLevelId;
        }
        if (this.searchValue.engageForm) {
          url += "&engageForm=" + this.searchValue.jobLevelId;
        }
        if (this.searchValue.departmentId) {
          url += "&departmentId=" + this.searchValue.departmentId;
        }
        if (this.searchValue.beginDateScope) {
          url += '&beginDateScope=' + this.searchValue.beginDateScope;
        }
        if (this.empName) {
          url += "&name=" + this.empName;
        }
        }else{
          url += '&name=' + this.empName
        }
        this.getRequest(url).then((resp) => {
          this.loading = false;
          if (resp) {
            // 后端返回的数据里面一个data，一个total
            this.emps = resp.data;
            this.total = resp.total;
          }
        });
    },
  },
};
</script>

<style>
/* 可以设置不同的进入和离开动画 */
/* 设置持续时间和动画函数 */
.slide-fade-enter-active {
  transition: all 0.8s ease;
}
.slide-fade-leave-active {
  transition: all 0.8s cubic-bezier(1, 0.5, 0.8, 1);
}
.slide-fade-enter, .slide-fade-leave-to
/* .slide-fade-leave-active for below version 2.1.8 */ {
  transform: translateX(10px);
  opacity: 0;
}
</style>